草庐IT

c++ - std::map 线程安全

全部标签

dictionary - 如何尽可能均匀地随机分割 Go 中的 map ?

我有一个简短的问题。我对golang很陌生。假设我有一张这样的map:map[int]string我怎样才能将它随机分成两个映射或数组,并尽可能接近偶数?因此,例如,如果有15个项目,它将拆分为7-8。 最佳答案 例如:funcsplit(mmap[int]string)(oddsmap[int]string,evensmap[int]string){n:=1odds=make(map[int]string)evens=make(map[int]string)forkey,value:=rangem{ifn%2==0{evens[k

go - 在 golang 中如何测试 map 或 channel 未初始化

varmmap[int]intvarcchanint如何用make测试m和c是否未初​​始化 最佳答案 您可以将这些值与nil进行比较,以查看它们是否已初始化。例如:varmmap[int]intvarcchanintfmt.Println("ismuninitialized:",m==nil)//truefmt.Println("iscuninitialized:",c==nil)//truem=make(map[int]int)c=make(chanint)fmt.Println("ismuninitialized:",m==n

multithreading - Golang线程不是每次都执行

这个问题在这里已经有了答案:Nooutputfromgoroutine(3个答案)Goroutinedoesnotexecuteiftime.Sleepincluded(1个回答)关闭4年前。所以,我正在测试Golang。我知道fmt.Println不是线程安全的。所以,我尝试了sync.Mutex。程序如下:functhreder(mux*Mutex,iint){mux.Lock()fmt.Println("Iamthread:",i)mux.Unlock()return}funcmain(){m:=&Mutex{}fori:=0;i我期待300行输出。但是,我得到80-90行。我哪

go - 为什么即使有锁,GO 也会出现 'concurrent map writes' panic ?

当尝试将此结构与多个goroutine一起使用时,有时我会遇到以下错误之一:fatalerror:并发映射读取和映射写入或并发映射写入看完thisthread我确保在构造函数中返回一个引用,并将一个引用传递给接收者。使用它的完整代码在thisgithubrepo中typeconcurrentStoragestruct{sync.Mutexdomainstringurlsmap[url.URL]bool}funcnewConcurrentStorage(dstring)*concurrentStorage{return&concurrentStorage{domain:d,urls:ma

for-loop - 更新 map 中的键,同时遍历该 map

我想使用URL参数将key从一个名称更新为另一个名称。我有代码,但输出不正确。见下文。这是mapvardatamap[string][]string调用函数的PUT方法r.HandleFunc("/updatekey/{key}/{newkey}",handleUpdateKey).Methods("PUT")handleUpdateKey函数,它被记录下来并准确解释了它在做什么。funchandleUpdateKey(whttp.ResponseWriter,r*http.Request){params:=mux.Vars(r)k:=params["key"]//geturlpara

pointers - Go中如何使用map作为数据载体?

我不确定正确的术语,但我该如何使用它:typeMyTypemap[string]string作为“数据载体”(或OOP中的对象)?这不起作用:funcNewMyType()*MyType{returnmake(MyType)}我确实想使用指针,但显然这不起作用,编译器期望在返回时引用。 最佳答案 内置make()函数创建MyType映射类型的非指针值,但返回类型是指针。如果您尝试编译它,错误消息会告诉您:cannotusemake(MyType)(typeMyType)astype*MyTypeinreturnargument如果您

go - 使用 goroutine 的多线程

我正在尝试使用Go来自动化我的侦察工具。到目前为止,我可以在kali(Nikto/whois)中运行两个基本工具。现在我希望它们并行执行,而不是等待一个函数完成。阅读了一下之后,我开始知道这可以通过使用goroutines来实现。但我的代码似乎不起作用:packagemainimport("log""os/exec""os""fmt")varurlstringfuncnikto(){cmd:=exec.Command("nikto","-h",url)cmd.Stdout=os.Stdouterr:=cmd.Run()iferr!=nil{log.Fatal(err)}}funcwho

go - 由于 slice 中的项目数正在变化,如何安全地从 slice 中删除项目

在我遍历用户slice后,我需要根据某些条件从slice中删除一些用户。我将多次遍历此用户slice,慢慢删除一些元素。我从其他语言了解到,在循环时从集合中删除项目是不安全的。所以我正在做的是将我想要删除的元素存储在maptoMutate中。原始循环完成后,我会继续尝试从slice中删除元素。toMutate:=make(map[int]User,100)foridx,u:=rangec.users{ifsomeCondition{toMutate[idx]=u}}然后我调用此函数从用户的slice中删除项目。foridx,u:=rangetoMutate{c.users=append

c - 与 c 相比,Go 的二进制大小

这个问题在这里已经有了答案:ReasonforhugesizeofcompiledexecutableofGo(3个答案)关闭6年前。昨天我只是想比较简单的golangHelloWorld应用程序和c,gobinary是2-3MB(只是fmt.Println)然而,等效的C代码只有大约20kb(printf)。然后我检查了两个二进制文件正在执行的系统调用,使用strace;两者之间没有太大区别,所以你知道为什么golang二进制文件与等效的c语言相比如此庞大吗?

go - 如何反转 golang map 中项目的顺序?

这个问题在这里已经有了答案:Collectvaluesinorder,eachcontainingamap(7个答案)关闭4年前。我是golang的新手,我想颠倒映射中对的出现顺序,以便最后一对排在第一位:mapA:=map[string]int{"cat":5,"dog":2,"fish":3,}fmt.Println(mapA)map[cat:5dog:2fish:3]生成的map应该是这样的:map[fish:3dog:2cat:5]它可以是一个新的mapB,具有相同的项目但顺序颠倒。我怎样才能做到这一点?